package Sort;

import java.util.Arrays;

public class BubbleSort {
    /* 冒泡排序 */
    public void bubbleSort(int[] nums) {
        int n = nums.length;
        // 外循环：未排序区间为 [0, i]
        for (int i = n - 1; i > 0; i--) {
            boolean flag = false;
            // 内循环：将未排序区间 [0, i] 中的最大元素交换至该区间的最右端
            for (int j = 0; j < i; j++) {
                if (nums[j] > nums[j + 1]) {
                    int temp = nums[j + 1];
                    nums[j + 1] = nums[j];
                    nums[j] = temp;
                    flag = true;
                }
            }
            if (flag == false) {
                break;
            }
        }
    }

    public static void main(String[] args) {
        BubbleSort sort = new BubbleSort();
        int[] nums = new int[] { 4, 4, 3, 1, 5, 2 };
        sort.bubbleSort(nums);
        System.out.println(Arrays.toString(nums));
    }

}

